<template>
<v-card class="mt-6">
  <v-toolbar flat>
    <v-menu offset-y>
      <template v-slot:activator="{ on, attrs }">
        <v-btn v-bind="attrs" v-on="on" small>
          Actions <v-icon right>mdi-chevron-down</v-icon>
        </v-btn>
      </template>
      <v-list dense>
      </v-list>
    </v-menu>
    <v-spacer></v-spacer>
    <v-text-field
      v-model="search"
      prepend-inner-icon="mdi-magnify"
      placeholder="Search"
      filled
      outlined
      dense
      hide-details
      />
  </v-toolbar>

  <v-data-table
    v-model="selected"
    :headers="headers"
    :items="identities"
    :search="search"
    item-key="identity"
    class="elevation-1"
    show-select
    >
    <template v-slot:item.tags="{ item }">
      <v-chip v-for="(tag, index) in item.tags"
              :key="tag.name"
              :color="(tag.type !== 'idt') ? 'primary' : 'default'"
              :class="(index > 0) ? 'ml-2' : ''"
              small
              >
        {{ tag.label }}
      </v-chip>
    </template>
    <template v-slot:item.actions="{ item }">
      <div class="text-right">
        <v-menu offset-y>
          <template v-slot:activator="{ on, attrs }">
            <v-btn icon v-bind="attrs" v-on="on">
              <v-icon>mdi-dots-horizontal</v-icon>
            </v-btn>
          </template>
          <menu-items :items="getMenuItems(item)" :object="item" />
        </v-menu>
      </div>
    </template>
  </v-data-table>
  <confirm-dialog ref="confirmAlias" />
  <confirm-dialog ref="confirmAccount">
    <v-checkbox v-model="keepAccountFolder"
                :label="'Do not delete account folder'|translate"
                hide-details
                />
  </confirm-dialog>
</v-card>
</template>

<script>
import { bus } from '@/main'
import identities from '@/api/identities'
import accounts from '@/api/accounts'
import aliases from '@/api/aliases'
import ConfirmDialog from '@/components/layout/ConfirmDialog'
import MenuItems from '@/components/tools/MenuItems'

export default {
  components: {
    ConfirmDialog,
    MenuItems
  },
  data () {
    return {
      headers: [
        { text: this.$gettext('Name'), value: 'identity' },
        { text: this.$gettext('Fullname/recipient'), value: 'name_or_rcpt' },
        { text: this.$gettext('Tags'), value: 'tags' },
        { text: this.$gettext('Actions'), value: 'actions', sortable: false, align: 'right' }
      ],
      identities: [],
      keepAccountFolder: false,
      search: '',
      selected: []
    }
  },
  methods: {
    async deleteAlias (alias) {
      const confirm = await this.$refs.confirmAlias.open(
        this.$gettext('Warning'),
        this.$gettext(
          'Do you really want to delete the alias %{ alias }?',
          { alias: alias.identity }
        ),
        {
          color: 'error',
          cancelLabel: this.$gettext('No'),
          agreeLabel: this.$gettext('Yes')
        }
      )
      if (!confirm) {
        return
      }
      aliases.delete(alias.pk).then(() => {
        bus.$emit('notification', { msg: this.$gettext('Alias deleted') })
        this.fetchIdentities()
      })
    },
    async deleteAccount (account) {
      const confirm = await this.$refs.confirmAccount.open(
        this.$gettext('Warning'),
        this.$gettextInterpolate(
          'Do you really want to delete the account %{ account }?',
          { account: account.identity }
        ),
        {
          color: 'error',
          cancelLabel: this.$gettext('No'),
          agreeLabel: this.$gettext('Yes')
        }
      )
      if (!confirm) {
        return
      }
      const data = { keepdir: this.keepAccountFolder }
      accounts.delete(account.pk, data).then(() => {
        bus.$emit('notification', { msg: this.$gettext('Account deleted') })
        this.keepAccountFolder = false
        this.fetchIdentities()
      }).catch(error => {
        bus.$emit('notification', { msg: error.response.data, type: 'error' })
      })
    },
    editAccount (account) {
      this.$router.push({ name: 'AccountEdit', params: { id: account.pk } })
    },
    editAlias (alias) {
      this.$router.push({ name: 'AliasEdit', params: { id: alias.pk } })
    },
    fetchIdentities () {
      identities.getAll().then(resp => {
        this.identities = resp.data
      })
    },
    getMenuItems (item) {
      const result = []
      if (item.type === 'account') {
        result.push({ label: this.$gettext('Edit'), icon: 'mdi-circle-edit-outline', onClick: this.editAccount })
        result.push({ label: this.$gettext('Delete'), icon: 'mdi-delete-outline', onClick: this.deleteAccount, color: 'red' })
      } else if (item.type === 'alias') {
        result.push({ label: this.$gettext('Edit'), icon: 'mdi-circle-edit-outline', onClick: this.editAlias })
        result.push({ label: this.$gettext('Delete'), icon: 'mdi-delete-outline', onClick: this.deleteAlias, color: 'red' })
      }
      return result
    }
  },
  mounted () {
    this.fetchIdentities()
  }
}
</script>
